Classe de conexão com banco de dados PostGreSQL [golfinho/Elefante]

Publicado por Emiliano Eloi Silva Barbosa 04/04/2007

[ Hits: 11.799 ]

Homepage: http://emilianoeloi.com.br

Download class.database.php




Tradução do script php de leo genilhu:

http://www.vivaolinux.com.br/scripts/verScript.php?codigo=257

Classe de conexão com banco de dados PostGreSQL, com métodos de inserção e atualização de query's.

Ótimo para quem esta iniciando OOP.

  



Esconder código-fonte

class database{

    var $db_HOST = "";
    var $db_PORT = "";
    var $db_USER = "";
    var $db_PASS = "";
    var $db = "";
    var $CONST_ERRO = "erro ao conectar no nosso banco"; 
    var $dbc;
    var $last_id;


    function database($db, $user, $pass="nopass",$host="localhost", $port=5432){
        $this->db_HOST=$host;
        $this->db_PORT=$port;
        $this->db_USER=$user;
        $this->db_PASS=$pass;
        $this->db=$db;
        
        $this->connect_db();
    }

    function connect_db(){
        $connect_string = "host=".$this->db_HOST." port=".$this->db_PORT." user=".$this->db_USER." password=".$this->db_PASS." dbname=".$this->db;
        $this->dbc = pg_connect($connect_string);
        return $dbc;
    }  

    function delete_db($table,$id){
        $Campo_id = $this->getPrimaryKey($table);
        $tmp="delete from $table where $Campo_id='$id'";
        $sts = pg_query($this->dbc,$tmp) or die($this->CONST_ERRO . pg_last_error());
        return $sts ;
    } 

    function close_db (){
        pg_close($this->dbc);
    }
    
    function insere_db($campos,$valores,$tab){
        $inicio="INSERT INTO $tab(";
        $meio=") VALUES (";
        $fim=")";
        $valor = sizeof($campos);
        $strc="";
        for($i=0;$i <= ($valor-1);$i++){
            $strc.="$campos[$i]";
            if($i != ($valor-1)){
                $strc.=",";
            }
        }
        $strv="";
        for($k=0;$k <= ($valor-1);$k++){
            $strv.="'$valores[$k]'";
            if($k != ($valor-1)){
                $strv.=",";
            }
        }
        $insere="$inicio$strc$meio$strv$fim";

        $this->query_db($insere);
        
        $this->setLastID($tab);
    }

    function query_db($sql){
        return pg_query($this->dbc,$sql) or die($this->CONST_ERRO . pg_last_error());
    }

    function reg_db($table){
        $tmp="select * from $table";
        $sts = pg_query($this->dbc,$tmp) or die($this->CONST_ERRO . pg_last_error());
        $num = pg_num_rows($sts);
        return($num);
    }
    
    function getPrimaryKey($table){
        $sql = "select indexdef from pg_indexes where tablename = '$table' and indexname LIKE '%pkey';";
        $res = pg_query($this->dbc,$sql) or die($this->CONST_ERRO . pg_last_error());
        $resultado = pg_fetch_result($res, 'indexdef');
            $arr_temp = explode("(",$resultado);
            $arr_temp2 = $arr_temp[1];
            $arr_temp = explode(")",$arr_temp2);
        return $arr_temp[0];
    }
    
    function setLastID($table){
        $sequence_name = $table . "_" . $this->getPrimaryKey($table) . "_seq";
        $sql = "select currval('$sequence_name') AS lastid";
        $res = pg_query($this->dbc,$sql) or die($this->CONST_ERRO . pg_last_error());
        $this->last_id = pg_fetch_result($res,'lastid');
    }

    function id_db(){
        return $this->last_id; 
    } 
};

Scripts recomendados

Função para criação de grid (tabela) dinâmico

Script Para Conectar-se Ao Banco de dados MYSQL

Backup com php, usando mysql_dump

Backup do MySQL via PHP

De data para date


  

Comentários

Nenhum comentário foi encontrado.


Contribuir com comentário




Patrocínio

Site hospedado pelo provedor RedeHost.
Linux banner

Destaques

Artigos

Dicas

Tópicos

Top 10 do mês

Scripts